|
4 | 4 | from kitsune.users.models import Profile
|
5 | 5 | from kitsune.users.tests import GroupFactory, UserFactory
|
6 | 6 | from kitsune.wiki.handlers import DocumentListener
|
7 |
| -from kitsune.wiki.tests import DocumentFactory, HelpfulVoteFactory |
| 7 | +from kitsune.wiki.models import Document, Revision |
| 8 | +from kitsune.wiki.tests import DocumentFactory, HelpfulVoteFactory, RevisionFactory |
8 | 9 |
|
9 | 10 |
|
10 | 11 | class TestDocumentListener(TestCase):
|
@@ -85,3 +86,41 @@ def test_anonymize_votes(self):
|
85 | 86 | # The rest should remain untouched.
|
86 | 87 | self.assertTrue(v2.creator)
|
87 | 88 | self.assertFalse(v2.anonymous_id)
|
| 89 | + |
| 90 | + def test_non_approved_revision_handling(self): |
| 91 | + """Test handling of non-approved revisions when a user is deleted.""" |
| 92 | + doc_to_delete = DocumentFactory(current_revision=None) |
| 93 | + RevisionFactory(document=doc_to_delete, creator=self.user, is_approved=False) |
| 94 | + |
| 95 | + doc_to_keep = DocumentFactory() |
| 96 | + other_user = UserFactory() |
| 97 | + approved_rev = RevisionFactory(document=doc_to_keep, creator=other_user, is_approved=True) |
| 98 | + doc_to_keep.current_revision = approved_rev |
| 99 | + doc_to_keep.save() |
| 100 | + non_approved_rev = RevisionFactory( |
| 101 | + document=doc_to_keep, creator=self.user, is_approved=False |
| 102 | + ) |
| 103 | + |
| 104 | + doc_to_reassign = DocumentFactory() |
| 105 | + approved_user_rev = RevisionFactory( |
| 106 | + document=doc_to_reassign, creator=self.user, is_approved=True |
| 107 | + ) |
| 108 | + doc_to_reassign.current_revision = approved_user_rev |
| 109 | + doc_to_reassign.save() |
| 110 | + |
| 111 | + self.listener.on_user_deletion(self.user) |
| 112 | + |
| 113 | + self.assertFalse(Document.objects.filter(id=doc_to_delete.id).exists()) |
| 114 | + |
| 115 | + self.assertTrue(Document.objects.filter(id=doc_to_keep.id).exists()) |
| 116 | + doc_to_keep.refresh_from_db() |
| 117 | + |
| 118 | + self.assertTrue(Revision.objects.filter(id=approved_rev.id).exists()) |
| 119 | + |
| 120 | + self.assertFalse(Revision.objects.filter(id=non_approved_rev.id).exists()) |
| 121 | + |
| 122 | + self.assertTrue(Document.objects.filter(id=doc_to_reassign.id).exists()) |
| 123 | + doc_to_reassign.refresh_from_db() |
| 124 | + self.assertEqual( |
| 125 | + doc_to_reassign.current_revision.creator.username, settings.SUMO_BOT_USERNAME |
| 126 | + ) |
0 commit comments